home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Chip 2007 January, February, March & April
/
Chip-Cover-CD-2007-02.iso
/
Pakiet multimedia
/
Muzyka
/
Edytory sampli (probek dzwieku)
/
ZynAddSubFX_2.2.0
/
Setup_ZynAddSubFX-2.2.0.exe
/
source code
/
UI
/
WidgetPDial.fl
< prev
Wrap
Text File
|
2005-03-14
|
3KB
|
132 lines
# data file for the Fltk User Interface Designer (fluid)
version 1.0105
header_name {.h}
code_name {.cc}
decl {//Copyright (c) 2003-2005 Nasca Octavian Paul} {}
decl {//License: GNU GPL version 2} {}
decl {\#include <FL/Fl_Dial.H>} {public
}
decl {\#include <FL/fl_draw.H>} {public
}
decl {\#include <stdio.h>} {public
}
decl {\#include <math.h>} {public
}
class WidgetPDial {: {public Fl_Dial}
} {
Function {WidgetPDial(int x,int y, int w, int h, const char *label=0):Fl_Dial(x,y,w,h,label)} {} {
code {oldvalue=0.0;} {}
}
Function {handle(int event)} {return_type int
} {
code {double dragsize,v,min=minimum(),max=maximum();
int my;
switch (event){
case FL_PUSH:oldvalue=value();
case FL_DRAG:
my=-(Fl::event_y()-y()-h()/2);
dragsize=200.0;
if (Fl::event_state(FL_BUTTON1)==0) dragsize*=10;
v=oldvalue+my/dragsize*(max-min);
if (v<min) v=min;
else if (v>max) v=max;
//printf("%d %g %g\\n",my,v,oldvalue);
value(v);
value_damage();
if (this->when()!=0) do_callback();
return(1);
break;
case FL_RELEASE:
if (this->when()==0) do_callback();
return(1);
break;
};
return(0);} {selected
}
}
Function {drawgradient(int cx,int cy,int sx,double m1,double m2)} {return_type void
} {
code {for (int i=(int)(m1*sx);i<(int)(m2*sx);i++){
double tmp=1.0-pow(i*1.0/sx,2.0);
pdialcolor(140+(int) (tmp*90),140+(int)(tmp*90),140+(int) (tmp*100));
fl_arc(cx+sx/2-i/2,cy+sx/2-i/2,i,i,0,360);
};} {}
}
Function {draw()} {} {
code {int cx=x(),cy=y(),sx=w(),sy=h();
//clears the button face
pdialcolor(190,190,200);
fl_pie(cx-1,cy-1,sx+2,sy+2,0,360);
//Draws the button face (gradinet)
drawgradient(cx,cy,sx,0.5,1.0);
double val=(value()-minimum())/(maximum()-minimum());
//draws the scale
pdialcolor(220,220,250);
double a1=angle1(),a2=angle2();
for (int i=0;i<12;i++){
double a=-i/12.0*360.0-val*(a2-a1)-a1;
fl_pie(cx,cy,sx,sy,a+270-3,a+3+270);
};
drawgradient(cx,cy,sx,0.0,0.75);
//draws the value
double a=-(a2-a1)*val-a1;
//draws the max and min points
pdialcolor(0,100,200);
int xp=(int)(cx+sx/2.0+sx/2.0*sin(angle1()/180.0*3.141592));
int yp=(int)(cy+sy/2.0+sy/2.0*cos(angle1()/180.0*3.141592));
fl_pie(xp-2,yp-2,4,4,0,360);
xp=(int)(cx+sx/2.0+sx/2.0*sin(angle2()/180.0*3.141592));
yp=(int)(cy+sy/2.0+sy/2.0*cos(angle2()/180.0*3.141592));
fl_pie(xp-2,yp-2,4,4,0,360);
fl_push_matrix();
fl_translate(cx+sx/2,cy+sy/2);
fl_rotate(a-90.0);
fl_translate(sx/2,0);
fl_begin_polygon();
pdialcolor(0,0,0);
fl_vertex(-10,-4);
fl_vertex(-10,4);
fl_vertex(0,0);
fl_end_polygon();
fl_pop_matrix();} {}
}
Function {pdialcolor(int r,int g,int b)} {} {
code {if (active_r()) fl_color(r,g,b);
else fl_color(160-(160-r)/3,160-(160-b)/3,160-(160-b)/3);} {}
}
decl {double oldvalue;} {}
}